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CLAIMS 

What is claimed is: 

method of determining clock insertion delays for a microprocessor design 
having grid-baseaclock distribution, the method comprising: 
5 partitioning\ie complete clock net into a globa l clock net and a plurality of lo cal clock 

nets; 

simulating eachlbf the plurality of local clock nets to generate a load for each of the 
plurality of local clock nefe on the global clock net; 

simulating the global clock net based in part on the simulated load of each of the plurality 

C3 

lQjj of local clock nets; and 

combining the plurality^of simulations to form the complete clock net. 

2. The method as defined in claim 1, wherein partitioning comprises breaking the 
complete clock net into a plurality of parts approximating rectangular grid coordinates. 

3. The method as defined in claim 1, further comprising breaking at least one of the 
plurality of local clock nets down into at least one sub-local clock net. 
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4. The method as defined in claim 3, further comprising simulating the at least one 
20 sub-local clock net prior to simulating the corresponding local clock net. 

5. The method as defined in claim 1, wherein at least two of the plurality of local 
clock nets are simulated in parallel. 
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6. The method as defined in claim 1, wherein simulating each of the plurality of 
local clock nets comprises: 

extracting a layout of the local clock net and the conductors routed above and through the 
local clock net from a microprocessor network database; 

extracting component values of the elements of the local clock net from the 
microprocessor network database; 

simulating the local clock net based on the layout and the component values; and 

extracting a load of the local clock net on the global clock net. 

7. The method as defined in claim 6, wherein simulating the local clock net 
comprises assuming that the clock arrival times from the global clock net will be simultaneous at 



in 

fU all points where the local clock net is connected to the global clock net. 



15^ 8. The method as defined in claim 1, wherein simulating the global clock net 

□ 

I comprises: 

extracting the layout of the global clock net from a microprocessor network database; 

extracting component values of the elements of the global clock net from the 
microprocessor network database; 
20 inserting the simulated loads of the plurality of local clock nets; and 

simulating the global clock net based on the layout, the component values, and the 
simulated local clock net loads. 
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9. The method as defined in claim 1, further comprising storing the plurality of 
simulation results in a Clock Data Model. 

10. The method as defined in claim 1, further comprising evaluating the complete 
5 clock net to determine whether the results converge. 

11. The method as defined in claim 10, wherein, if the results do not converge, the 
method further comprises: 

assuming that clock arrival times are those calculated for the simulated global clock net; 
re-simulating at least one of the plurality of local clock nets to generate a load for the at 
least one local clock net on the global clock net; 

re-simulating the global clock net based in part on the simulated or re-simulated load of 
each of the plurality of local clock nets; and 

combining the simulations and re-simulations to form the complete clock net. 

12. The method as defined in claim 11, wherein re-simulating at least one of the 
plurality of local clock nets comprises: 

re-simulating the at least one local clock net based on the layout, the component values, 
and the calculated clock arrival times; and 

extracting a load of the at least one local clock net on the global clock net. 

13. The method as defined in claim 12, further comprising re-simulating at least a 
second of the plurality of local clock nets in parallel with the at least one local clock net. 
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14. The method as defined in claim 1 1, wherein re-simulating the global clock net 
comprises: 

inserting the simulated or re-simulated loads of the plurality of local clock nets; and 
5 re-simulating the global clock net based on the layout, the component values, and the 

simulated or re-simulated local clock net loads. 
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15. The method as defined in claim 11, further comprising storing the plurality of 
simulation and re-simulation results in a Clock Data Model. 




A\apparatus for determining clock insertion delays for a microprocessor design 
having grid-based crock distribution, the apparatus comprising: 

means for part\oning the complete clock net into a global clock net and a plurality of 
local clock nets; 

means for simulatin\each of the plurality of local clock nets to generate a load for each 
of the plurality of local clock nets on the global clock net; 

means for simulating the\global clock net based in part on the simulated load of each of 
the plurality of local clock nets; 

means for combining the plurality of simulations to form the complete clock net. 

17. The apparatus as defined in claim 16, wherein means for partitioning comprises 
means for breaking the complete clock net into a plurality of parts approximating rectangular 
grid coordinates. 



20 



EL839722862US 



Docket No. SUN-P5403 



18. The apparatus as defined in claim 16, further comprising means for breaking at 
least one of the plurality of local clock nets down into at least one sub-local clock net. 

5 19. The apparatus as defined in claim 18, further comprising means for simulating the 

at least one sub-local clock net prior to simulating the corresponding local clock net. 

20. The apparatus as defined in claim 16, wherein at least two of the plurality of local 
clock nets are simulated in parallel. 

%Q 

21. The apparatus as defined in claim 16, wherein means for simulating each of the 

ru 

a p plurality of local clock nets comprises: 

in 

jfU means for extracting a layout of the local clock net and the conductors routed above and 

S"* through the local clock net from a microprocessor network database; 
C-3 

15^ means for extracting component values of the elements of the local clock net from the 

2 microprocessor network database; 

means for simulating the local clock net based on the layout and the component values; 

and 

means for extracting a load of the local clock net on the global clock net. 
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22. The apparatus as defined in claim 21, wherein means for simulating the local 
clock net comprises means for assuming that the clock arrival times from the global clock net 
will be simultaneous at all points where the local clock net is connected to the global clock net. 
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23. The apparatus as defined in claim 16, wherein means for simulating the global 
clock net comprises: 

means for extracting the layout of the global clock net from a microprocessor network 
5 database; 

means for extracting component values of the elements of the global clock net from the 
microprocessor network database; 

means for inserting the simulated loads of the plurality of local clock nets; and 

means for simulating the global clock net based on the layout, the component values, and 

10*!! the simulated local clock net loads. 
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c p 24. The apparatus as defined in claim 16, further comprising means for storing the 

in 

jfU plurality of simulation results in a Clock Data Model. 
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15^ 25. The apparatus as defined in claim 16, further comprising means for evaluating the 

P complete clock net to determine whether the results converge. 

26. The apparatus as defined in claim 25, wherein the apparatus further comprises: 
means for assuming that clock arrival times are those calculated for the simulated global 
20 clock net; 

means for re-simulating at least one of the plurality of local clock nets to generate a load 
for the at least one local clock net on the global clock net; 
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means for re-simulating the global clock net based in part on the simulated or re- 
simulated load of each of the plurality of local clock nets; and 

means for combining the simulations and re-simulations to form the complete clock net. 

27. The apparatus as defined in claim 26, wherein means for re-simulating at least one 
of the plurality of local clock nets comprises: 

means for re-simulating the at least one local clock net based on the layout, the 
component values, and the calculated clock arrival times; and 

means for extracting a load of the at least one local clock net on the global clock net. 



28. The apparatus as defined in claim 27, further comprising means for re-simulating 
at least a second of the plurality of local clock nets in parallel with the at least one local clock 
fU net. 



G 

15H 29. The apparatus as defined in claim 26, wherein means for re-simulating the global 

J\ clock net comprises: 

means for inserting the simulated or re-simulated loads of the plurality of local clock 
nets; and 

means for re-simulating the global clock net based on the layout, the component values, 
20 and the simulated or re-simulated local clock net loads. 

30. The apparatus as defined in claim 26, further comprising means for storing the 
plurality of simulation and re-simulation results in a Clock Data Model. 
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31. \An apparatus for determining clock insertion delays for a microprocessor design 
having grid-based clock distribution, the apparatus comprising: 

a parti tionerVor horizontally and vertically partitioning the complete clock net into a 
global clock net and aYlurality of local clock nets; 

at least one local cbck net simulator for simulating at least one of the plurality of local 
clock nets to generate a load \>r the at least one local clock net on the global clock net; 

a global clock net simulator for simulating the global clock net based in part on the 
simulated load of each of the plurality of local clock nets; and 



IG3 a merging unit for combining^he plurality of simulations to form the complete clock net. 



32. The apparatus as defined in claim 31, wherein the partitioner comprises a cutter 
for breaking the complete clock net into a plurality of parts approximating rectangular grid 
coordinates, 

33. The apparatus as defined in claim 31, wherein the partitioner vertically sub- 
partitions at least one of the plurality of local clock nets down into at least one sub-local clock 
net. 



20 34. The apparatus as defined in claim 33, wherein the at least one local clock net 

simulator simulates the at least one sub-local clock net prior to simulating the corresponding 
local clock net. 
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35. The apparatus as defined in claim 31, further comprising at least a second local 
clock net simulator wherein at least a second of the plurality of local clock nets is simulated in 
parallel with the at least one local clock net. 

36. The apparatus as defined in claim 31, wherein the at least one local clock net 
simulator comprises: 

a layout extractor for extracting a layout of the local clock net and the conductors routed 
above and through the local clock net from a microprocessor network database; 

a component value extractor for extracting component values of the elements of the local 
clock net from the microprocessor network database; 

a local clock net simulator for simulating the local clock net based on the layout and the 
component values; and 

a load extractor for extracting a load of the local clock net on the global clock net. 

37. The apparatus as defined in claim 36, wherein the local clock net simulator 
assumes for the simulation that the clock arrival times from the global clock net will be 
simultaneous at all points where the local clock net is connected to the global clock net. 

38. The apparatus as defined in claim 31, wherein the global clock net simulator 
20 comprises: 

a layout extractor for extracting the layout of the global clock net from a microprocessor 
network database; 
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a component extractor for extracting component values of the elements of the global 
clock net from the microprocessor network database; 

a load insertion unit for inserting the simulated loads of the plurality of local clock nets; 

and 

a simulator for simulating the global clock net based on the layout, the component values, 
and the simulated local clock net loads. 

39. The apparatus as defined in claim 31, further comprising a Clock Data Model for 
storing the plurality of simulation results. 



ry 40. The apparatus as defined in claim 31, further comprising a convergence evaluator 

ss 

in for evaluating the complete clock net to determine whether the results converge. 
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P 41. The apparatus as defined in claim 40, wherein, when the results are found not to 

15*j converge: 

the apparatus assumes that clock arrival times are those calculated for the simulated 
global clock net; 

the at least one local clock net simulator re-simulates at least one of the plurality of local 
clock nets to generate a load for the at least one local clock net on the global clock net; 
20 the global clock net simulator re-simulates the global clock net based in part on the 

simulated or re-simulated load of each of the plurality of local clock nets; and 

the merging unit combines the simulations and re-simulations to form the complete clock 

net. 
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42. The apparatus as defined in claim 41, further comprising a Clock Data Model for 
storing the plurality of simulation and re-simulation results. 




iA computer-readable medium having stored thereon computer-executable 
instructions forroerforming a method of determining clock insertion delays for a microprocessor 
design having grim-based clock distribution, the method comprising: 

partitioning\he complete clock net into a global clock net and a plurality of local clock 

nets; 

simulating each\>f the plurality of local clock nets to generate a load for each of the 
plurality of local clock nels on the global clock net; 

simulating the globaj clock net based in part on the simulated load of each of the plurality 
of local clock nets; and 

combining the plurality^ simulations to form the complete clock net. 

44. The computer-readable medium as defined in claim 43, wherein partitioning 
comprises breaking the complete clock net into a plurality of parts approximating rectangular 
grid coordinates. 



20 45. The computer-readable medium as defined in claim 43, wherein the method 

further comprises breaking at least one of the plurality of local clock nets down into at least one 
sub-local clock net. 
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46. The computer-readable medium as defined in claim 45, wherein the method 
further comprises simulating the at least one sub-local clock net prior to simulating the 
corresponding local clock net. 

5 47. The computer-readable medium as defined in claim 43, wherein at least two of the 

plurality of local clock nets are simulated in parallel. 

48. The computer-readable medium as defined in claim 43, wherein simulating each 
of the plurality of local clock nets comprises: 

Q 

lQ[g extracting a layout of the local clock net and the conductors routed above and through the 

tip 

$} local clock net from a microprocessor network database; 



ru 



«|* extracting component values of the elements of the local clock net from the 

in 

microprocessor network database; 

simulating the local clock net based on the layout and the component values; and 

U 

lij extracting a load of the local clock net on the global clock net. 
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49. The computer-readable medium as defined in claim 48, wherein simulating the 
local clock net comprises assuming that the clock arrival times from the global clock net will be 
simultaneous at all points where the local clock net is connected to the global clock net. 

50. The computer- readable medium as defined in claim 43, wherein simulating the 
global clock net comprises: 

extracting the layout of the global clock net from a microprocessor network database; 
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extracting component values of the elements of the global clock net from the 
microprocessor network database; 

inserting the simulated loads of the plurality of local clock nets; and 
simulating the global clock net based on the layout, the component values, and the 
5 simulated local clock net loads. 

51. The computer-readable medium as defined in claim 43, wherein the method 
further comprises storing the plurality of simulation results in a Clock Data Model. 



l(>g 52. The computer-readable medium as defined in claim 43, wherein the method 

further comprises evaluating the complete clock net to determine whether the results converge. 
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fij 53. The computer-readable medium as defined in claim 52, wherein, if the results do 

s 

?. 



l^T assuming that clock arrival times are those calculated for the simulated global clock net; 



% A not converge, the method further comprises: 

r 

« ** re-simulating at least one of the plurality of local clock nets to generate a load for the at 

least one local clock net on the global clock net; 

re-simulating the global clock net based in part on the simulated or re-simulated load of 
each of the plurality of local clock nets; and 
20 combining the simulations and re-simulations to form the complete clock net. 

54. The computer-readable medium as defined in claim 53, wherein re-simulating at 
least one of the plurality of local clock nets comprises: 
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re-simulating the at least one local clock net based on the layout, the component values, 
and the calculated clock arrival times; and 

extracting a load of the at least one local clock net on the global clock net. 

5 55. The computer-readable medium as defined in claim 54, wherein the method 

further comprises re-simulating at least a second of the plurality of local clock nets in parallel 
with the at least one local clock net. 

56. The computer-readable medium as defined in claim 53, wherein re-simulating the 

a 

global clock net comprises: 

I,. inserting the simulated or re-simulated loads of the plurality of local clock nets; and 

SU 
■J* 

1^ re-simulating the global clock net based on the layout, the component values, and the 

ru 

a simulated or re-simulated local clock net loads. 
"3 

15i 57. The computer-readable medium as defined in claim 53, wherein the method 

<L-A 

further comprises storing the plurality of simulation and re-simulation results in a Clock Data 
Model. 

A method determining and analyzing clock insertion delays for a 
20 microprocessor design havin\ grid-based clock distribution, the method comprising: 

partitioning the completkclock net into a global clock net and a plurality of local clock 

nets; 
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simulating each of the plurality of local clock nets to generate a load for each of the 
plurality of local ctock nets on the global clock net; 

simulating thegtobal clock net based in part on the simulated load of each of the plurality 
of local clock nets; 

5 combining the plurality ^simulations to form the complete clock net; and 

analyzing the complete cloclotet to predict the clock skew for a given data transfer path. 

59. The method as defined in claim 58, wherein analyzing comprises: 
adjusting an insertion delay of the involved elements of the given data transfer path; and 
re-simulating at least one local clock net involved in the given data transfer path. 

60. The method as defined in claim 59, further comprising, when the at least one re- 
simulated local clock net is connected to at least one sub-local clock net, evaluating the clock 
arrival times to determine whether the sub-local clock net should be re-simulated. 

61. The method as defined in claim 59, further comprising evaluating the at least one 
re-simulated local clock net load to determine whether at least one higher clock net connected to 
the at least one re-simulated local clock net should be re-simulated. 

62. The method as defined in claim 59, further comprising storing the plurality of 
simulation and re-simulation results in a Clock Data Model. 
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XNN \>3. \kn apparatus for determining clock insertion delays for a microprocessor design 
having grid-basey clock distribution, the apparatus comprising: 

means for partitioning the complete clock net into a global clock net and a plurality of 
local clock nets; \ 

means for simulMing each of the plurality of local clock nets to generate a load for each 
of the plurality of local closk nets on the global clock net; 

means for simulating che global clock net based in part on the simulated load of each of 
the plurality of local clock netsA 

means for combining the plurality of simulations to form the complete clock net; and 

means for analyzing the complete clock net to predict the clock skew for a given data 
transfer path. \ 

64. The apparatus as defined in claim 63, wherein means for analyzing comprises: 
means for adjusting an insertion delay of the involved elements of the given data transfer 

path; and 

means for re-simulating at least one local clock net involved in the given data transfer 

path. 

65. The apparatus as defined in claim 64, further comprising, when the at least one re- 
simulated local clock net is connected to at least one sub-local clock net, means for evaluating 
the clock arrival times to determine whether the sub-local clock net should be re-simulated. 
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66. The apparatus as defined in claim 64, further comprising means for evaluating the 
at least one re-simulated local clock net load to determine whether at least one higher clock net 
connected to the at least one re-simulated local clock net should be re-simulated. 



67. The apparatus as defined in claim 64, further comprising means for storing the 
plurality of simulation and re-simulation results in a Clock Data Model. 

n apparatus for determining clock insertion delays for a microprocessor design 
having grid-basedrclock distribution, the apparatus comprising: 

a partitionenfor horizontally and vertically partitioning the complete clock net into a 
global clock net and atolurality of local clock nets; 

at least one locaftclock net simulator for simulating at least one of the plurality of local 
clock nets to generate a load for the at least one local clock net on the global clock net; 

a global clock net simulator for simulating the global clock net based in part on the 
simulated load of each of the plurality of local clock nets; 

a merging unit for combining the plurality of simulations to form the complete clock net; 
and \ 

an analyzer for analyzing the\omplete clock net to predict the clock skew for a given 
data transfer path. \ 

69. The apparatus as defined in claim 68, wherein the analyzer comprises a redesign 
unit for adjusting an insertion delay of the involved elements of the given data transfer path, 




33 



EL839722862US 




Docket No. SUN-P5403 



wherein the at least one local clock net simulator re-simulates at least one local clock net 
involved in the given data transfer path. 

70. The apparatus as defined in claim 69, further comprising, when the at least one re- 
simulated local clock net is connected to at least one sub-local clock net, a clock arrival time 
evaluator for evaluating the clock arrival times to determine whether the sub-local clock net 
should be re-simulated. 

7 1 . The apparatus as defined in claim 69, further comprising a load evaluator for 
evaluating the at least one re-simulated local clock net load to determine whether at least one 
higher clock net connected to the at least one re-simulated local clock net should be re-simulated. 

72. The apparatus as defined in claim 69, further comprising a Clock Data Model for 
storing the plurality of simulation and re-simulation results. 



instructions for performing a method of determining clock insertion delays for a microprocessor 
design having grid-based clock distribution, the method comprising: 

partitioning the complete clock net into a global clock net and a plurality of local clock 
nets; \ 

simulating each of the plurality of local clock nets to generate a load for each of the 
plurality of local clock nets on the\lobal clock net; 




^computer-readable medium having stored thereon computer-executable 
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simulating the global clock net based in part on the simulated load of each of the plurality 
of local clock 

combining the^durality of simulations to form the complete clock net; and 
analyzing the complete clock net to predict the clock skew for a given data transfer path. 

74. The computer-readable medium as defined in claim 73, wherein analyzing 
comprises: 

adjusting an insertion delay of the involved elements of the given data transfer path; and 
re-simulating at least one local clock net involved in the given data transfer path. 

75. The computer-readable medium as defined in claim 74, wherein the method 

fU 

p further comprises, when the at least one re-simulated local clock net is connected to at least one 
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fU sub-local clock net, evaluating the clock arrival times to determine whether the sub-local clock 
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h A net should be re-simulated. 
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76. The computer-readable medium as defined in claim 74, wherein the method 
further comprises evaluating the at least one re-simulated local clock net load to determine 
whether at least one higher clock net connected to the at least one re-simulated local clock net 
should be re-simulated. 

77. The computer-readable medium as defined in claim 74, wherein the method 
further comprises storing the plurality of simulation and re-simulation results in a Clock Data . 
Model. 
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